home *** CD-ROM | disk | FTP | other *** search
/ Revista do CD-ROM 101 / CD-ROM 101.iso / compl / maya5ple / Install_MayaPLE5_English.exe / Maya / Data1.cab / bindCurvesToStrokes.mel < prev    next >
Encoding:
Text File  |  2003-07-17  |  2.0 KB  |  58 lines

  1. // Copyright (C) 1997-2002 Alias|Wavefront,
  2. // a division of Silicon Graphics Limited.
  3. //
  4. // The information in this file is provided for the exclusive use of the
  5. // licensees of Alias|Wavefront.  Such users have the right to use, modify,
  6. // and incorporate this code into other products for purposes authorized
  7. // by the Alias|Wavefront license agreement, without fee.
  8. //
  9. // ALIAS|WAVEFRONT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
  10. // INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO
  11. // EVENT SHALL ALIAS|WAVEFRONT BE LIABLE FOR ANY SPECIAL, INDIRECT OR
  12. // CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
  13. // DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  14. // TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  15. // PERFORMANCE OF THIS SOFTWARE.
  16. //
  17. //
  18. // attach picked control nurbs curves to picked strokes 
  19. //
  20.  
  21. global proc bindCurvesToStrokes()
  22. {
  23.     int $i, $j, $k;
  24.  
  25.     string $strokes[] = `ls -dag -sl -typ stroke`;
  26.     string $curves[] = `ls -dag -sl -typ nurbsCurve`;
  27.  
  28.     for( $i = 0; $i < size( $strokes ); $i++ )
  29.     {
  30.         string $existingConnections[] = `listConnections ($strokes[$i] + ".controlCurve")`;
  31.         for( $j = 0; $j < size( $existingConnections ); $j++ )
  32.         {
  33.             string $con[] = `listConnections ($strokes[$i] + ".controlCurve[" + $j + "]")`;
  34.             for( $k = 0; $k < size( $con ); $k++ )
  35.             {
  36.                 disconnectAttr ($con[$k] + ".worldSpace") ($strokes[$i] + ".controlCurve[" + $j + "]" );
  37.             }
  38.         }
  39.         for( $j = 0; $j < size( $curves ); $j++ )
  40.         {
  41.             string $node[] = `duplicateCurve -o false $curves[$j]`;
  42.             if( size($node) > 0 ) 
  43.             {
  44.                 if( "nurbsCurve" == `nodeType $node[0]`) 
  45.                 {
  46.                     connectAttr -f ($curves[$j] + ".worldSpace") ($strokes[$i] + ".controlCurve[" + $j + "]" );
  47.                 }
  48.                 else
  49.                 {
  50.                     // TODO: check for existing curveFromSurface, rather than always creating new ones
  51.                     connectAttr -f ($node[0] + ".oc") ($strokes[$i] + ".controlCurve[" + $j + "]" );
  52.                 }
  53.             }
  54.         }
  55.     }
  56. }
  57.  
  58.